草庐IT

c++ - 长整数和 float

全部标签

ruby - 将 ruby float 向上或向下舍入到最接近的 0.05

我得到像这样的数字2.363636363636364.5675631.23456646544846510.5857447736我如何让Ruby将这些数字向上(或向下)舍入到最接近的0.05? 最佳答案 [2.36363636363636,4.567563,1.23456646544846,10.5857447736].mapdo|x|(x*20).round/20.0end#=>[2.35,4.55,1.25,10.6] 关于ruby-将rubyfloat向上或向下舍入到最接近的0.05

ruby-on-rails - ruby 整数到 bool 值

我有一个整数类型的数据库字段,值始终为0或1。如何在ruby​​中获取等效的bool值?这样当我执行以下操作时,复选框就会被适本地设置: 最佳答案 您可以使用zero?方法。如果为0,则返回true。如果需要向后,可以轻松地将其取反为!@system_config.resend.zero?。或者您可以扩展Fixnum类,添加一个to_b?方法,因为一切都是开放的并且可以在动态语言中扩展。classIntegerdefto_b?!self.zero?endendrubyAPI:http://ruby-doc.org/core/clas

ruby - 如何将 boolean 值转换为整数?

我有一个boolean值来检查它是否为真,然后设置一个局部变量。我该如何重构它,使其更像Ruby?iffirm.inflection_pointinflection_point=1elseinflection_point=0end 最佳答案 inflection_point=(firm.inflection_point?1:0) 关于ruby-如何将boolean值转换为整数?,我们在StackOverflow上找到一个类似的问题: https://stack

如果整数,则 Ruby 将 float 舍入为 int

在ruby​​中,如果float是整数,我想将其转换为int。例如a=1.0b=2.5a.to_int_if_whole#=>1b.to_int_if_whole#=>2.5基本上,我试图避免在任何没有小数的数字上显示“.0”。我正在寻找一种优雅的(或内置的)方式来做defto_int_if_whole(float)(float%1==0)?float.to_i:floatend 最佳答案 一个简单的方法是:classFloatdefprettifyto_i==self?to_i:selfendend那是因为:irb>1.0==1=

ruby - 检查 Float 是否等同于 Ruby 中的整数值

假设我有以下代码:x=0.8y=1.0检查y是否等同于Integer的最佳方法是什么?目前我在做:y.to_int==y这行得通,但我觉得应该有更好的方法。 最佳答案 您用1mod值,并检查该值是否等于0。ify%1==0 关于ruby-检查Float是否等同于Ruby中的整数值,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5083202/

ruby - ruby 中字符的整数值?

我希望在ruby​​1.9.2中将字符'a'变成97ruby1.8.7irb(main):001:0>?a=>97ruby1.9.2irb(main):001:0>?a=>"a" 最佳答案 你可能想要String#ord:%irbruby-1.9.2-head>'a'.ord=>97 关于ruby-ruby中字符的整数值?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/41112

ruby - 如果 float 不是 .00 则只显示小数点 sprintf/printf

我很喜欢格式化一个float,但如果没有相关的float,我希望它显示为一个整数。即1.20->1.2x1.78->1.78x0.80->0.8x2.00->2x我可以通过一些正则表达式来实现这一点,但想知道是否有一个sprintf-only方法可以做到这一点?我在ruby​​中懒洋洋地这样做:("%0.2fx"%(factor/100.0)).gsub(/\.?0+x$/,'x') 最佳答案 您想使用%g而不是%f:"%gx"%(factor/100.00) 关于ruby-如果floa

ruby - 如何最好地在两个 float 之间的范围内创建一个随机 float

我知道我可以用rand(max)生成随机float。我试图生成一个范围内的float,这应该不难。但是例如rand(1.4512)返回0,因此rand不是用float计算的。现在我尝试了一个小技巧,将它转换为一个整数,然后在我想要的范围内随机化一个合适的数字后,将它计算回一个float......这是行不通的。我的问题是如何以更好的方式做到这一点。如果没有更好的方法,为什么这个方法不起作用?(也许对我来说太晚了,我应该在2小时前开始sleep……)。整个事情旨在成为一种计算数据库记录“位置”字段的方法,以便用户可以手动订购它们。我以前从未做过这样的事情,也许有人可以用更好的解决方案提示

ruby-on-rails - 为什么最好将电话号码存储为字符串而不是整数?

如问题所述,为什么将电话号码作为字符串而不是整数存储在telephone_number列中被认为是最佳实践?不确定我是否理解这样做的理由。请帮忙解决这个问题!谢谢! 最佳答案 电话号码是数字字符串,不是整数。例如考虑:用不同的基数表示电话号码会使它变得毫无意义将两个电话号码相加或相乘,或者对电话号码进行任何数学运算,都是没有意义的。结果不是另一个电话号码(巧合除外)电话号码应“按原样”输入连接的设备。电话号码可以有前导零。电话号码的操作,例如添加区号,是字符串操作。存储电话号码的字符串版本使其清晰明确。历史:在旧的脉冲编码拨号系统中

ruby - 严格将字符串转换为整数(或零)

对于网络编程,数字以字符串形式出现。但是to_i会将"5abc"转换为5并将"abc"转换为0,都是错误的答案。为了捕获这些,我写道:defnumber_or_nil(s)number=s.to_inumber=nilif(number.to_s!=s)returnnumberend是否有一种更简洁、更符合Ruby标准的方法来完成此转换并检测该字符串不是数字? 最佳答案 使用整数(字符串)如果字符串无法转换为整数,它将引发ArgumentError错误。Integer('5abc')#=>ArgumentError:invalidv